草庐IT

c++ - std::string 和 UTF-8 编码的 unicode

全部标签

html - 如何在 Ruby 中编码/解码 HTML 实体?

我正在尝试解码一些HTML实体,例如'&lt;'成为'.我有一个旧gem(html_helpers),但它似乎已经被遗弃了两次。有什么建议吗?我需要在模型中使用它。 最佳答案 要对字符进行编码,可以使用CGI.escapeHTML:string=CGI.escapeHTML('test"escaping"')要解码它们,有CGI.unescapeHTML:CGI.unescapeHTML("test"unescaping"<characters>")当然,在此之前你需要包含CGI库:requi

ruby-on-rails - 使用带有无效字符的 Net::FTP gettextfile(ASCII-8BIT 与 UTF-8)

我有一个通过FTP从大型机获取平面文件的进程。这通常工作正常,但有时文件会包含一些重音字符。如果我尝试获取包含口音的文件,整个过程会失败并出现以下错误:Encoding::UndefinedConversionError:"\x88"fromASCII-8BITtoUTF-8那是使用Net::FTP的gettextfile方法。许多人建议简单地切换到getbinaryfile-这样做将允许我下载文件,但生成的文件是我无法再解析的东西(说它是UTF-8,但内容使没有意义)。有没有什么方法可以简单地获取文件并将其保存为ASCII,而无需让Rails自动将输出转换为UTF-8?这是我的代码:

ruby - 在 String 子类上覆盖 =~ 方法会产生不一致

我为String的子类覆盖了=~方法:classMyString重写的方法在某些情况下被正确调用:r=/abc/s=~r#=>"Overriddenmethod."s.send(:=~,r)#=>"Overriddenmethod."s.send(:=~,/abc/)#=>"Overriddenmethod."而在其他情况下它被绕过,而是调用String#=~:s=~/abc/#=>0s=~(/abc/)#=>0我可以在Ruby1.8.7、2.1.0上重现这些结果。有人知道为什么会这样吗?是错误吗? 最佳答案 在String#=~的

ruby-on-rails - to_json 不将特殊字符转换为 unicode 样式

我在将哈希值转换为json字符串时遇到特殊字符问题。Ruby2.0/Rails3.2.21一切正常,也就是说,puts"“".to_json#"\u201c"但是使用Ruby2.3.0/Rails4.2.5.1我明白了puts"“".to_json#"“"有什么方法可以强制Ruby2.3.0将特殊字符转换为unicode样式字符串(\uXXXX)?备注:注意在Ruby2.3/Rails4中,我们得到"“".to_json.bytesize==5#true但是,在2.0中我们得到"“".to_json.bytesize==8#true很明显,不同的是字符串本身,而不是不同的输出格式。

ruby-on-rails - Ruby 2.2:PG::CharacterNotInRepertoire:错误:编码 "UTF8"的无效字节序列

我正在升级Rails4.1应用程序以使用Ruby2.2。在升级期间,事实证明该应用程序使用了旧版本的pggem(0.12),并且gem没有使用Ruby2.2安装。所以我尝试使用更新版本的pggem(0.17.1)。现在在系统中创建新用户时有时会出现以下错误:PG::CharacterNotInRepertoire:ERROR:invalidbytesequenceforencoding"UTF8"Ruby2.2和Postgres是否存在任何已知问题?看起来应用程序配置为使用unicode:config.encoding="utf-8"在application.rb中设置,encodin

ruby - Ruby 中 Windows 上的 Unicode 文件名

我有一段代码看起来像这样:Dir.new(path).eachdo|entry|putsentryend当我列出的目录中有一个名为こんニちは世界.txt的文件时,问题就来了。在Windows7机器上我得到输出:???????.txt通过谷歌搜索,在Windows上正确读取此文件名似乎是一项不可能完成的任务。有什么建议吗? 最佳答案 我遇到了同样的问题,只是想出了如何在Windows中获取UTF-8目录的条目。以下对我有用(使用Ruby1.9.2p136):opts={}opts[:encoding]="UTF-8"entries=D

ruby-on-rails - 编码::UndefinedConversionError: "\xE4"从 ASCII-8BIT 到 UTF-8

我试图获取这个CSV-File使用Net::HTTP。File.open(file,"w:UTF-8")do|f|content=Net::HTTP.get_response(URI.parse(url)).bodyf.write(content)end再次读取我的本地csv文件后,我得到了一些奇怪的输出。Nationalit\xE4t;Alter0-5我尝试将其编码为UTF-8,但出现错误Encoding::UndefinedConversionError:"\xE4"fromASCII-8BITtoUTF-8rchardetgem告诉我内容是ISO-8859-2。但转换为UTF-8

ruby-on-rails - "Ascii85":String

安装rails时遇到问题,不断收到此ascii85字符串错误的错误(/usr/lib/ruby/gems/1.8/gems/rails-2.3.11/lib/rails/gem_dependency.rb:277:in`==':undefinedmethod`name'for"Ascii85":String(NoMethodError)).如果有人经历过这个。 最佳答案 它看起来像是RubyGems中的错误:http://rubyforge.org/tracker/index.php?func=detail&aid=29188&gr

ruby - String.scan 和 String.split 的区别

这两个(String#scan和String#split)在Ruby中有什么区别? 最佳答案 它们的用途完全不同。String#scan用于从字符串中提取正则表达式的匹配项并返回数组中的匹配项,而String#split旨在根据分隔符将字符串拆分为数组。分隔符可以是静态字符串(如;在单个分号上拆分)或正则表达式(如/\s/+在任何空白字符上拆分).String#split的输出不包含分隔符。相反,除了定界符之外的所有内容都将在输出数组中返回,而String#scan的输出将仅包括与定界符匹配的内容。#Adelimitedstring

STM32F103C8T6编码器电机的使用

目录前言一、定时器部分和按键部分二、PWM调速三、电机驱动部分​​​​​​​三、编码器接口部分(测速)四.主函数总结​​​​​​​推荐STM32学习课程:[6-8]编码器接口测速_哔哩哔哩_bilibili[6-8]编码器接口测速是STM32入门教程-2022持续更新中的第20集视频,该合集共计30集,视频收藏或关注UP主,及时了解更多相关视频内容。https://www.bilibili.com/video/BV1th411z7sn/?p=20&spm_id_from=pageDriver&vd_source=ed36b2700bbc2bac7746c270bc391540OLED显示屏代码